<template>
    <UPloader action="/api/utils/upload-multiple"
        :show-upload-list="false"
        :before-upload="commonUploadCheck"
        :uploaded="uploaded"
        class="styled-uploader" @on-success="handleUploadSuccess">
        <template #default>
            <div class="uploader-container">
                <FileImageOutlined />
                <h4>{{ props.text }}</h4>
            </div>
        </template>
        <template #loading>
            <div class="uploader-container">
                <LoadingOutlined spin />
                <h4>上传中</h4>
            </div>
        </template>
        <template #uploaded="dataProps">
            <div class="uploader-container">
                <img :src="dataProps.uploadedData.data.urls[0]" v-if="showUploaded" />
                <template v-else>
                    <FileImageOutlined />
                    <h4>{{ props.text }}</h4>
                </template>
            </div>
        </template>
    </UPloader>

</template>
<script setup lang="ts">
import { FileImageOutlined, LoadingOutlined } from '@ant-design/icons-vue'
import UPloader from '@/components/UPloader.vue'
import type { UploadFile } from '@/components/UPloader.vue'
import { commonUploadCheck } from '@/constant/helper'
const props = defineProps({
    text: { type: String, default: '点击上传' },
    showUploaded: { type: Boolean, default: true },
    uploaded: {
      type: Object
    }
})
const emits = defineEmits<{ success: [resp: UploadResp, file: File] }>()

const handleUploadSuccess = ({ resp, file }: { resp: UploadResp; file: UploadFile }) => {
    emits('success', resp, file.raw)
}

</script>
<style lang="scss" scoped>
.styled-uploader {
    .uploader-container {
        width: 100px;
        padding: 10px;
        color: #ffffff;
        background: #1890ff;
        display: flex;
        justify-content: center;
        align-items: center;
        border-radius: 5px;
        cursor: pointer;
        transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
    }

    .uploader-container:hover {
        background: #40a9ff;
    }

    .uploader-container h4 {
        color: #ffffff;
        margin-bottom: 0;
        margin-left: 10px;
    }

    .uploader-container img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
}
</style>